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1 INTRODUCTION 

The W65C02S is a low power cost sensitive 8-bit microprocessor. The W65C02S is a fiilly static core and the PHI2 clock 
can be stopped when it is in the high (logic 1) or low (logic 0) state. The variable length instruction set and manually 
optimized core size makes the W65C02S an excellent choice for low power System-on-Chip (SoC) designs. The Verilog 
RTL model is available for ASIC design flows. WDC, a Fabless Semiconductor Company, provides packaged chips for 
evaluation or volume production. To aid in system development, WDC provides a Development System that includes a 
W65C02DB Developer Board, an In-Circuit Emulator (ICE) and the W65cSDS Software Development System, see 
www.westemdesigncenter.com for more information. 

1.1 Features of the W65C02S 

• 8-bit data bus 

• 1 6-bit address bus provides access to 65,536 bytes of memory space 

• 8-bit ALU, Accumulator, Stack Pointer, Index Registers, Processor Status Register 

• 1 6-bit Program Counter 

• 69 instructions 

• 16 addressing modes 

• 212 Operation Codes (OpCodes) 

• Vector Pull (VPB) output indicates when interrupt vectors are being addressed 

• WAit-for-Interrupt (WAI) and SToP (STP) instructions reduce power consumption, decrease interrupt latency and 
provide synchronization with extemal events 

• Variable length instruction set provides for lower power and smaller code optimization over fixed length instruction 

set processors 

• Fully static circuitry 

• Wide operating voltage range, 1.8+/- 5%, 2.5+/- 5%, 3.0+/- 5%, 3.3+/- 10%, 5.0+/- 5% specified 

• Low Power consumption, 150uA@lMHz 
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2 FUNCTIONAL DESCRIPTION 

The internal organization of the W65C02S is divided into two parts: 1) Register Section and 2) Control Section. 
Instructions obtained from program memory are executed by implementing a series of data transfers within the 
Register Section. Signals that cause data fransfers are generated within the Confrol Section. 

2.1 Instruction Register (IR) and Decode 

The Operation Code (OpCode) portion of the instruction is loaded into the Instruction Register from the Data Bus 
and is latched during the OpCode fetch cycle. The OpCode is then decoded, along with timing and interrupt signals, 
to generate various confrol signals for program execution. 

2.2 Timing Control Unit (TCU) 

The Timing Control Unit (TCU) provides timing for each instruction cycle that is executed. The TCU is set to zero for each 
instruction fetch, and is advanced at the beginning of each cycle for as many cycles as is required to complete the instruction. 
Data transfers between registers depend upon decoding the contents of both the IR and the TCU. 

2.3 Arithmetic and Logic Unit (ALU) 

All arithmetic and logic operations take place within the ALU. In addition to data operations, the ALU also 
calculates the effective address for relative and indexed addressing modes. The result of a data operation is stored in 
either memory or an internal register. Carry, Negative, Overflow and Zero flags are updated following the ALU data 
operation. 

2.4 Accumulator Register (A) 

The Accumulator Register (A) is an 8-bit general purpose register which holds one of the operands and the result of 
arithmetic and logical operations. Reconfigured versions of this processor family could have additional 
acciunulators. 

2.5 Index Registers (X and Y) 

There are two 8-bit Index Registers (X and Y) which may be used as general purpose registers or to provide an index 
value for calculation of the effective address. When executing an instruction with indexed addressing, the 
microprocessor fetches the OpCode and the base address, and then modifies the address by adding the Index 
Register contents to the address prior to performing the desired operation. 

2.6 Processor Status Register (P) 

The 8-bit Processor Status Register (P) contains status flags and mode select bits. The Carry (C), Negative (N), 
Overflow (V) and Zero (Z) status flags serve to report the status of ALU operations. These status flags are tested 
with Conditional Branch instructions. The Decimal (D) and IRQB disable (I) are used as mode select flags. These 
flags are set by the program to change microprocessor operations. Bit 5 is available for a user status or mode bit. 

2.7 Program Counter Register (PC) 
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The 16-bit Program Counter Register (PC) provides the addresses which are used to step the microprocessor through 
sequential program instructions. This register is incremented each time an instruction or operand is fetched from 
program memory. 

2.8 Stack Pointer Register (S) 

The Stack Pointer Register (S) is an 8-bit register which is used to indicate the next available location in the stack 
memory area. It serves as the effective address in stack addressing modes as well as subroutine and interrupt 
processing. 
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Figure 2-1 W65C02S Internal Architecture Simplified Block Diagram 
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C Processor Status Register "P" 
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Figure 2-2 W65C02S Microprocessor Programming Model 
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PIN FUNCTION DESCRIPTION 



3.1 Address Bus (A0-A15) 

The sixteen bit Address Bus formed by A0-A15, address memory and I/O registers that exchange data on the Data 
Bus. The address lines can be set to the high impedance state by the Bus Enable (BE) signal. 

3.2 Bus Enable (BE) 

The Bus Enable (BE) input signal provides external control of the Address, Data and the RWB buffers. When Bus 
Enable is high, the Address, Data and RWB buffers are active. When BE is low, these buffers are set to the high 
impedance status. Bus Enable is an asynchronous signal. 

3.3 Data Bus (D0-D7) 

The eight Data Bus lines D0-D7 are used to provide instructions, data and addresses to the microprocessor and 
exchange data with memory and I/O registers. These lines may be set to the high impedance state by the Bus Enable 
(BE) signal. 

3.4 Interrupt Request (IRQB) 

The Interrupt Request (IRQB) input signal is used to request that an interrupt sequence be initiated. The program 
counter (PC) and Processor Status Register (P) are pushed onto the stack and the IRQB disable (I) flag is set to a "1" 
disabling further interrupts before jiunping to the interrupt handler. These values are used to return the processor to 
its original state prior to the IRQB interrupt. The IRQB low level should be held until the interrupt handler clears 
the interrupt request source. When Return from Interrupt (RTI) is executed the (I) flag is restored and a new 
interrupt can be handled. If the (I) flag is cleared in an interrupt handler, nested interrupts can occur. The Wait-for- 
Interrupt (WAI) instruction may be used to reduce power and synchronize with, as an example timer interrupt 
requests. 

3.5 Memory Lock (MLB) 

The Memory Lock (MLB) output may be used to ensure the integrity of Read-Modify- Write instructions in a 

multiprocessor system. Memory Lock indicates the need to defer arbitration of the bus cycle when MLB is low. 
Memory Lock is low during the last three cycles of ASL, DEC, INC, LSR, ROL, ROR, TRB, and TSB memory 
referencing instructions. 

3.6 Non-Maskable Interrupt (NMIB) 

A negative transition on the Non-Maskable Interrupt (NMIB) input initiates an interrupt sequence after the current 
instruction is completed. Since NMIB is an edge-sensitive input, an interrupt will occur if there is a negative 
transition while servicing a previous interrupt. Also, after the edge interrupt occurs no ftirther interrupts vwU occur if 
NMIB remains low. The NMIB signal going low causes the Program Counter (PC) and Processor Status Register 
information to be pushed onto the stack before jumping to the interrupt handler. These values are used to return the 
processor to it's original state prior to the NMIB interrupt. 
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3.7 No Connect (NC) 

The No Connect (NC) pins are not connected internally and should not be connected externally. 

3.8 Phase 2 In (PHI2), Phase 2 Out (PHI20) and Phase 1 Out (PHIIO) 

Phase 2 In (PHI2) is the system clock input to the microprocessor internal clock. During the low power Standby 
Mode, PH12 can be held in either high or low state to preserve the contents of internal registers since the 
microprocessor is a fully static design. The Phase 2 Out (PH120) signal is generated from PHI2. Phase 1 Out 
(PHIIO) is the inverted PH12 signal. An external oscillator is recommended for driving PHI2 and used for the main 
system clock. All production test timing is based on PHI2. PHI20 and PHIIO were used in older systems for 
system timing and intemal oscillators when an external crystal was used. 

3.9 ReadAVrite (RWB) 

The ReadAVrite (RWB) output signal is used to control data fransfer. When in the high state, the microprocessor is 

reading data from memory or I/O. When in the low state, the Data Bus contains valid data to be written from the 
microprocessor and stored at the addressed memory or I/O location. The RWB signal is set to the high impedance 
state when Bus Enable (BE) is low. 

3.10 Ready (RDY) 

A low input logic level on the Ready (RDY) will halt the microprocessor in its current state. Returning RDY to the 
high state allows the microprocessor to continue operation following the next PHI2 negative transition. This bi- 
directional signal allows the user to single-cycle the microprocessor on all cycles including write cycles. A negative 
fransition to the low state prior to the falling edge of PHI2 vwU halt the microprocessor vwth the output address lines 
reflecting the current address being fetched. This assumes the processor setup time is met. This condition will 
remain through a subsequent PHI2 in which the ready signal is low. This feature allows microprocessor interfacing 
with low-speed memory as well as direct memory access (DMA). The WAI instruction pulls RDY low signaling the 
WAit-for-lnterrupt condition, thus RDY is a bi-directional pin. On the W65C02 hard core there is a WAIT output 
signal that can be used in ASIC's thus removing the bi-directional signal and RDY becomes only the input. In such 
a situation the WAI instruction will pull WAIT low and must be used external of the core to pull RDY low or the 
processor will continue as if the WAI never happened. The microprocessor will be released when RDY is high and 
a falling edge of PHI2 occurs. This again assumes the processor control setup time is met. The RDY pin has an 
active pull-up, when outputting a low level, the pull-up is disabled. The RDY pin can still be wire ORed. 
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3.11 Reset (RESB) 

The Reset (RESB) input is used to initialize the microprocessor and start program execution. The RESB signal must 

be held low for at least two clock cycles after VDD reaches operating voltage. Ready (RDY) has no effect while 
RESB is being held low. All Registers are initialized by software except the Decimal and Interrupt disable mode 
select bits of the Processor Status Register (P) are initialized by hardware. When a positive edge is detected, there 
wA\ be a reset sequence lasting seven clock cycles. The program counter is loaded with the reset vector from 
locations FFFC (low byte) and FFFD (high bj^e). This is the start location for program control. RESB should be 
held high after reset for normal operation. 

Processor Status Register (P) 
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3.12 Set Overflow (SOB) 

A negative transition on the Set Overflow (SOB) pin sets the overflow bit (V) in the status code register. The signal is 
sampled on the rising edge of PHI2. SOB was originally intended for fast input recognition because it can be tested 
with a branch instruction; however, it is not recommended in new system design and was seldom used in the past. 

3.13 SYNChronize with OpCode fetch (SYNC) 

The OpCode fetch cycle of the microprocessor instruction is indicated with SYNC high. The SYNC output is 
provided to identify those cycles during which the microprocessor is fetching an OpCode. The SYNC line goes high 
during the clock cycle of an OpCode fetch and stays high for the entire cycle. If the RDY line is pulled low during 
the clock cycle in which SYNC went high, the processor will stop in its current state and will remain in the state 
until the RDY line goes high. In this manner, the SYNC signal can be used to control RDY to cause single 
instruction execution. 

3.14 Power (VDD) and Ground (VSS) 

VDD is the positive power supply voltage and VSS is system logic ground. 

3.15 Vector PuU (VPB) 

The Vector Pull (VPB) output indicates that a vector location is being addressed during an interrupt sequence. VPB 

is low during the last interrupt sequence cycles, during which time the processor reads the interrupt vector. The 
VPB signal may be used to select and prioritize interrupts from several sources by modifying the vector addresses. 
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Table 3-1 Vector Locations 

FFFE, F BRK/IRQB Software/Hardware 

FFFC, D RESB Hardware 

FFFA, B NMIB Hardware 




Table 3-2 Pin Function Table 
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Figure 3-1 W65C02S 40 Pin PDIP Pinout 
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Figure 3-2 W65C02S 44 Pin PLCC Pinout 
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Figure 3-3 W65C02S 44 Pin QFP Pinout 
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4 ADDRESSING MODES 



The W65C02S is capable of directly addressing 65,536 bytes of memory. The Program Address and Data Address space is 
contiguous throughout the 65,536 byte address space. Words, arrays, records, or any data structures may span the 65,536 
byte address space. The following addressing mode descriptions provide additional detail as to how effective addresses are 
calculated. Sixteen addressing modes are available for the W65C02S. This address space has special significance within 
certain addressing modes. 

4.1 Absolute a 

With Absolute addressing the second and third bytes of the instruction form the 16-bit address. 
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Byte: 

Instruction: 
Operand Address: 
4.2 Absolute Indexed Indirect (a,x) 

With the Absolute Indexed Indirect addressing mode, the X Index Register is added to the second and third byes of the 
instruction to form an address to a pointer. This address mode is only used with the JMP instruction and the program 
Counter is loaded with the first and second bytes at this pointer. 
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4.3 Absolute Indexed with X a,x 

With the Absolute Indexed with X addressing mode, the X Index Register is added to the second and third bytes of the 
instruction to form the 16-bits of the effective address. 
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4.4 Absolute Indexed with Y a, y 

With the Absolute Indexed with Y addressing mode, the Y Index Register is added to the second and third bytes of the 
instruction to form the 16-bit effective address. 
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Instruction: 
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Operand address: 
4.5 Absolute Indirect (a) 

With the Absolute Indirect addressing mode, the second and third bytes of the instruction form an address to a pointer. This 
address mode is only used with the JMP instruction and the Program Counter is loaded with the first and second bytes at this 
pointer. 
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4.6 Accumulator A 

With Accumulator addressing the operand is implied as the Accumulator and therefore only a single byte forms the 
instruction.. 
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Operand: 

4.7 Immediate Addressing # 

With Immediate Addressing the operand is the second byte of the instruction. 
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4.8 Implied i 

Implied addressing uses a single byte instruction. The operand is imphcitly defmed by the instruction. 
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4.9 Program Counter Relative r 



The Program Counter relative addressing mode, sometimes referred to as Relative Addressing, is used with the Branch 
instructions. If the condition being tested is met, the second byte of the instruction is added to the Program Counter and 
program control is transferred to this new memory location. 
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offset 


OpCode 



PCH 


PCL 




offset 


effective address 



4,10 Stacks 

The Stack may use memory from 0100 to OlFF and the effective address of the Stack address mode will always be within 
this range. Stack addressing refers to all instructions that push or pull data from the stack, such as Push, Pull, Jump to 
Subroutine, Return from Subroutine, Interrupts and Return from Interrupt. 



Byte: 

Instruction: 



2 


1 







OpCode 



1 



Operand address: 
4.11 Zero Page zp 

With Zero Page (zp) addressing the second byte of the instruction is the address of the operand in page zero. 



2 


1 







zp 


OpCode 



Byte: 

Instruction: 
Operand address: 
4.12 Zero Page Indexed Indirect (zp,x) 

The Zero Page Indexed Indirect addressing mode is often referred to as Indirect,X. The second byte of the instruction is the 
zero page address to which the X Index Register is added and the result points to the low byte of the indirect address. 



Byte: 

Instruction: 
Base Address: 
Indirect Address: 
Operand address: 



2 


1 







zp 


OpCode 



+ 


zp 


X 





address 



indirect address 
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4.13 Zero Page Indexed with X zp,x 



With Zero Page Indexed with X addressing mode, the X Index Register is added to the second byte of instruction to form the 
effective address. 



2 


1 







zp 


OpCode 



Byte: 

Instruction: 
Base Address: 
Operand Address: 
4,14 Zero Page Indexed with Y zp, y 

With Zero Page Indexed with Y addressing, the second byte of the instruction is the zero page address to which the Y Index 
Register is added to form the page zero effective address. 



+ 


zp 


X 





effective address 



2 


1 







zp 


OpCode 



Byte: 

Instruction: 
Base Address: 
Operand Address: 
4.15 Zero Page Indirect (zp) 

With Zero Page Indirect addressing mode, the second byte of the instruction is a zero page indirect address that points to the 
low byte of a two byte effective address. 



+ 


zp 


Y 





effective address 



2 


1 







zp 


OpCode 



Byte: 

Instruction: 
Indirect Address: 
Operand Address: 
4.16 Zero Page Indirect Indexed with Y (zp), y 

The Zero Page Indirect Indexed with Y addressing mode is often referred to as Indirect Y. The second byte of the instruction 
points to the low byte of a two byte (16-bit) base address in page zero. Y Index Register is added to the base address to form 
the effective address. 



indirect address 



Byte: 

Instruction: 

Indirect Base Address: 



Operand Address: 



2 


1 







zp 


OpCode 



indirect base address 



Y 



effective address 
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Table 4-1 Addressing Mode Table 



Address Mode 


Instruction Times in Memory 
Cycle 


Memory Utilization in Number of 
Program Sequence Bytes 




Original 
NMOS 6502 


W65C02S 


Original 
NMOS 6502 


W65C02S 


1. Absolute a 


4(3) 


4(3) 


3 


3 


2. Absolulc Indexed Indirect (a.x) 


5 


5 


3 


3 


3 . Absolute Indexed with X a,x 


4(1,3) 


4(1,3) 


3 


3 


4. Absolute Indexed with Y a,y 


4(1) 


4(1) 


3 


3 


5. Absolute Indirect (a) 


4(3) 


4(3) 


3 


3 


6. Accumulator A 


2 


2 


1 


1 


7. Immediate # 


2 


2 


2 


2 


8. Implied i 


2 


2 


1 


1 


9. Program Counter Relative r 


2(2) 


2(2) 


2 


2 


10. Stacks 


3-7 


3-7 


1-3 


1-4 


11. Zero Page zp 


3(3) 


3(3) 


2 


2 


12. Zero Page Indexed Indirect (zp,x) 


6 


6 


2 


2 


13. Zero Page Indexed with X zp,x 


4(3) 


4(3) 


2 


2 


14. Zero Page Indexed with Y zp,y 


4 


4 


2 


2 


15. Zero Page Indirect (zp) 




5 




2 


16. Zero Page Indirect Indexed with Y (zp),y 


5 


5 


2 


2 



Notes: (indicated in parenthesis) 

1. Page boundary, add 1 cycle if page boundary is crossed when forming address 

2. Branch taken, add 1 cycle if branch is taken 

3. Read-Modify- Write, add 2 cycles 
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5 OPERATION TABLES 



Table 5-1 Instruction Set Table 



1. 


ADC 


ADd memory to accumulator with Carry 


2. 


AND 


"AND" memory with accumulator 


3. 


ASL 


Arithmetic Shift one bit Left, memory or 
accumulator 


4. 


•BBR 


Branch on Bit Reset 


5. 


•BBS 


Branch of Bit Set 


6. 


BCC 


Branch on Carry Clear (Pc=0) 


7. 


BCS 


Branch on Carry Set (Pc^l) 


8. 


BEQ 


Branch if HQual (Pz-1) 


9. 


BIT 


Bit Test 


10. 


BMI 


Branch if result Minus (Pn=l) 


11. 


BNE 


Branch if Not Equal (Pz=0) 


12. 


BPL 


Branch if result PLus (Pn=0) 


13. 


•BRA 


BRanch Always 


14. 


BRK 


BReaK instruction 


15. 


BVC 


Branch on oVerflow Clear (Pv— 0) 


16. 


BVS 


Branch on oVerflow Set (Pv=I) 


17. 


CLC 


CLear Cary flag 


18. 


CLD 


CLear Decimal mode 


19. 


CLI 


CLear Interrupt disable bit 


20. 


CLV 


CLear oVerflow flag 


21. 


CMP 


CoMPare memory and accumulator 


22. 


CPX 


ComPare memory and X register 


23. 


CPY 


ComPare memory and Y register 


24. 


DEC 


DECrement memory or accumulate by one 


25. 


DEX 


DEcrement X by one 


26. 


DEY 


DEcrement Y by one 


27. 


EOR 


"Exclusive OR" memory with acctjmulate 


28. 


INC 


INCrement memory or accumulate by one 


29. 


INX 


INcrement X register by one 


30. 


INY 


INcrement Y register by one 


31. 


JMP 


JuMP to new location 


32. 


JSR 


Jump to new location Saving Return (Jump to 
SubRoutine) 


33. 


LDA 


LoaD Accumulator with memory 


34. 


LDX 


LoaD the X register with memory 


35. 


LDY 


LoaD the Y register with memory 


36. 


LSR 


Logical Shift one bit Right memory or 
accumulator 



37. 


NOP 


No operation 


38. 


ORA 


"OR" memory with Accumulator 


39. 


PHA 


PusH Accumulator on stack 


40. 


PHP 


PusH Processor status on stack 


41. 


PHX 


PusH X register on stack 


42. 


PHY 


PusH Y register on stack 


43. 


PLA 


PuLl Accumulator fl-om stack 


44. 


PLP 


PuLl Processor status from stack 


45. 


•PLX 


PuLI X register Ironi slack 


46. 


•PLY 


PuLl Y register from stack 


47. 


•RMB 


Reset Memory Bit 


48. 


ROL 


Rotate one bit Left memory or accumulator 


49. 


ROR 


Rotate one bit Right memory or accumulator 


50. 


RTI 


ReTum from Interrupt 


51. 


RTS 


ReTum from Subroutine 


52. 


SBC 


SuBtract memory from accumulator with 
borrow (Carry bit) 


53. 


SED 


SEt Decimal mode 


54. 


SEI 


SEt Interrupt disable status 


55. 


•SMB 


Set Memory Bit 


56. 


STA 


STore Accumulator in memory 


57. 


•STP 


SToP mode 


58. 


STX 


STore the X register in memory 


59. 


STY 


STore the Y register in memory 


60. 


•STZ 


STore Zero in memory 


61. 


TAX 


Transfer the Accumulator to the X register 


62. 


TAY 


Transfer the Accumulator to the Y register 


63. 


•TRB 


Test and Reset memory Bit 


64. 


•TSB 


Test and Set memory Bit 


65. 


TSX 


Transfer the Stack pointer to the X register 


66. 


TXA 


Transfer the X register to the Accumulator 


67. 


TXS 


Transfer the X register to the Stack pointer 

register 


68. 


TYA 


Transfer Y register to the Accumulator 


69. 


•WAI 


WAit for Interrupt 



Note: •=New Instruction 
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Table 5-2 W65C02S OpCode Matrix 



S "1 o 




o 






m 




in 




1^ 


OO 




< 


CD 




Q 


m 






W65C02S OpCode Matrix 




BBROr 
5,3 • 


BBRlr 
5,3 • 


BBR2r 
5,3 • 


BBR3r 
5,3 • 


BBR4r 
5,3 • 


BBR5r 
5,3 • 


BBR6r 
5,3 • 


BBR7r 
5,3 • 


BBSOr 
5,3 • 


BBSl r 
5,3 • 


BBS2r 
5,3 • 


BBS3r 
5,3 • 


BBS4r 
5,3 • 


n 
-£\ 


BBS6r 
5,3 • 


BBS7r 
5,3 • 




w 


ASL a 
6,3 


ASL a,x 
6,3 


ROL a 

6,3 


ROL a,x 
6,3 


LSR a 

6,3 


LSR a,x 
6,3 


ROR a 

6,3 


ROR a,x 

6,3 


STX a 
4,3 


STZ a,x 
5,3 • 


LDX a 

4,3 


LDX a,y 
4,3 


DEC a 
6,3 


DEC a,x 
6,3 


INC a 
6,3 


INC a,x 
6,3 


w 


Q 


ORA a 

4,3 


ORAa,x 
4,3 


AND a 
4,3 


ANDa,x 
4,3 


EOR a 
4,3 


EOR a,x 
4,3 


ADC a 

4,3 


ADC a,x 

4,3 


STA a 
4,3 


STA a,x 
4,3 


LDA a 

4,3 


LDA a,x 
4,3 


CMP a 

4,3 


CMP a,x 
4,3 


SBC a 
4,3 


SBC a,x 
4,3 


Q 


O 


TSBa 
6,3 • 


TRBa 
6,3 • 


BIT a 
4,3 


BIT a,x 
4,3 * 


JMP a 

3,3 




JMP (a) 

6,3 


JMP (a,x) 
6,3 * 


STY a 
4,3 


STZ a 
4,3 • 


LDY a 
4,3 


LDY a,x 
4,3 


CPYa 
4,3 




CPXa 
4,3 




O 


m 


























WAIi 
3,1 • 


• 






CQ 


< 


ASL A 
2,1 


INC A 
2,1 * 


ROL A 
2,1 


DEC A 
2,1 * 


LSR A 
2,1 


PHYs 
3,1 • 


ROR A 

2,1 


PLYs 
4,1 • 


TXAi 
2,1 


TXSi 
2,1 


TAXi 
2,1 


TSXi 
2,1 


DEXi 
2,1 


PHXs 
3.1 • 


NOPi 
2,1 


PLXs 
4,1 • 


< 




ORA# 
2,2 


ORA a,y 
4,3 


AND# 
2,2 


AND a,y 
4,3 


EOR# 
2,2 


EOR a,y 
4,3 


ADC# 
2,2 


ADC a,y 
4,3 


BIT# 
2,2 


STA a,y 
5,3 


LDA# 
2,2 


LDA a,y 
4,3 


CMP# 
2,2 


CMP a.y 
4,3 


SBC# 
2,2 


SBC a,y 
4,3 




00 


PHPs 

3,1 


CLCi 
2,1 


PLPs 
4,1 


SECi 
2,1 


PHAs 

3,1 


CLIi 
2,1 


PLAs 
4,1 


SEIi 
2,1 


DEYi 
2,1 


TYAi 
2,1 


TAYi 
2,1 


CLVi 
2,1 


INYi 
2,1 


CLDi 
2,1 


INXi 
2,1 


SEDi 
2,1 


00 


r- 


RMBOzp 
5,2 • 


RMBl zp 
5,2 • 


RMB2zp 
5,2 • 


RMB3zp 
5,2 • 


RMB4zp 
5,2 • 


RMB5zp 
5,2 • 


RMB6zp 
5,2 • 


RMBTzp 
5,2 • 


SMBO zp 
5,2 • 


SMBl zp 
5,2 • 


SMB2 zp 
5,2 • 


SMB3 zp 
5,2 • 


SMB4 zp 
5,2 • 


SMB5 zp 
5.2 • 


SMB6 zp 
5,2 • 


SMB7 zp 
5,2 • 


r-~ 




ASLzp 
5,2 


ASL zp,x 
6,2 


ROLzp 
5,2 


ROL zp,x 
6,2 


LSRzp 
5,2 


LSR zp,x 
6,2 


RORzp 
5,2 


ROR zp,x 
6,2 


STXzp 
3,2 


STX zp,y 
4,2 


LDXzp 

3,2 


LDX zp,y 
4,2 


DECzp 
5,2 


DEC zp.x 
6,2 


INCzp 
5,2 


INC zp,x 
6,2 






ORA zp 

3,2 


ORA zp,x 
4,2 


ANDzp 
3,2 


AND zp,x 
4,2 


EORzp 
3,2 


EOR zp,x 
4,2 


ADCzp 
3,2 


ADC zp,x 
4,2 


STAzp 
3,2 


STA zp,x 
4,2 


LDAzp 

3,2 


LDA zp,x 
4,2 


CMPzp 
3,2 


CMP zp,x 
4,2 


SBCzp 
3,2 


SBC zp,x 
4,2 






TSBzp 
5,2 • 


TRBzp 
5,2 • 


BITzp 

3,2 


BIT zp,x 
4,2 * 






STZzp 
3,2 • 


STZ zp,x 
4,2 • 


STYzp 
3,2 


STY zp,x 
4,2 


LDYzp 

3,2 


LDY zp,x 
4,2 


CPYzp 
3,2 




CPXzp 
3,2 






m 




































(N 




ORA (zp) 
5,2 * 




N 

Q ^-^ 
< 




EOR (zp) 
5,2 * 




ADC (zp) 
5,2 * 




STA (zp) 
5,2 * 


LDX# 
2,2 


LDA (zp) 
5,2 * 




CMP (zp) 
5,2 * 




SBC (zp) 
5,2 * 


(N 




ORA (zp,x) 
6,2 


ORA (zp),y 
5,2 


AND (zp,x) 
6,2 


AND (zp),y 
5,2 


EOR (zp,x) 
6,2 


EOR (zp),y 
5,2 


ADC (zp,x) 
6,2 


ADC (zp),y 
5,2 


STA (zp,x) 
6,2 


STA (zp),y 
6,2 


LDA (zp,x) 
6,2 


'S 
Q 


CMP (zp,x) 
6,2 


CMP (zp),y 
5,2 


SBC (zp,x) 
6,2 


SBC (zp),y 
5,2 




O 


^ - 

Pi t-. 

CQ 


BPLr 

2,2 


JSRa 

6,3 


BMIr 

2,2 


RTIs 
6,1 


BVCr 
2,2 


RTSs 
6,1 


BVSr 
2,2 


BRAr 
3,2 • 


BCCr 
2,2 


LDY# 
2,2 


BCSr 
2,2 


CPY# 
2,2 


BNEr 
2,2 


CPX# 
2,2 


BEQr 
2,2 


O 


S Q 




o 














1^ 


00 




< 


m 


u 


Q 


M 







-o 
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6 DC, AC AND TIMING CHARACTERISTICS 



Table 6-1 Absolute Maximum Ratings 



Rating 


Symbol 


Value 


Supply Voltage 


VDD 


-0.3 to +7.0V 


Input Voltage 


VIN 


-0.3 to VDD +0.3V 


Storage Temperature 


TS 


-55°Cto+150°C 



This device contains input protection against damage due to high static voltages or electric fields; however, precautions should be taken 
to avoid application of voltages higher than the maximum rating. 

Note: Exceeding these ratings may result in permanent damage. Fimctional operation imder these conditions is not implied. 
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6.1 DC Characteristics TA = -40 ° C to +85 ° C (PLCC, QFP) TA= ° C to 70°C (DIP) 



Table 6-2 DC Characteristics 



Symbol 


5.0 +/- 5% 


3.3+/- 10% 


3.0 +/- 5% 


2.5 +1- 5% 


1.8+/- 5% 


Units 
























VDD 


Supply Voltage 


4,75 


5.25 


3.0 


3.6 


2.85 


3.15 


2.37 


2.63 


1.71 


1.89 


Y 


Vih 


Input High Voltage (1) 
BE, D0-D7, RDY, SOB 
IRQB, NMIB, PHI2, RESB 


VDDxO.7 

VDD-0.4 


VDI>K),3 
VDD+0.3 


VDD,x0.7 
VDD-0.4 


VDD+0.3 
VDD+0.3 


VDDxO.7 
VDD-0.4 


VDD-rO.3 
VDD+0.3 


VDDxO.7 
VDD-0.4 


VDD+0.3 
VDD+0.3 


VDD,\0.7 
VDD-0.4 


VDD+0.3 
VDD+0.3 


V 


Vil 


Input Low Voltage (1) 
BE, D0-D7, RDY, SOB, 
IRQB, NMIB, P1II2, RESB 


VSS-0.3 
VSS-0.3 


VDDxO.3 
VSS+0.4 


VSS-0.3 
VSS-0.3 


VDDxO.3 
VSS+0.4 


VSS-0.3 
VSS-0.3 


VDDxO.3 
VSS+0.4 


VSS-0.3 
VSS-0.3 


VDD,\0.3 
VSS+0.4 


VSS-0.3 
VSS-0.3 


VDDxO.3 
VSS+0.1 


V 


lin 


Input Leakage Current (Vin=0.4 to 2.4, VDD=max) 
BE, IRQB, NMIB, PHI2, RESB, SOB 


-20 


20 


-20 


20 


-20 


20 


-20 


20 


-20 


20 


nA 


Ipup 


RDY Input Pull-UP Current (Vin=VDD-0.4V (min) 

Vin=0.4(max)) 


-I 


-20 


-1 


-20 


-1 


-10 


-1 


-10 


-0.25 


-2.0 


HA 


lin 


D0-D7 (off state) 


-20 


20 


-20 


20 


-20 


20 


-20 


20 


-20 


20 


nA 


loh 


Output High current (Voh=VDD-.4, VDD=min) 
A0-A15, D0-D7, MLB, PHIIO, PHI20, RWB, SYNC, 
VPB 


700 




350 




300 




200 




100 




uA 


lol 


Output Low current (Vol=0.4, VDD=min) 
A0-AI5, D0-D7, MLB, PHIIO, PHI20, RWB, SYNC, 
VPB 


1.6 




1.6 




1.6 




1.0 




0.5 




mA 


Idd 


Supply Current (with Tester Loading) 
Supply Current (Core) 




1.5 
0.5 




1.0 
0.3 




1.0 
0.25 




0.75 
0.2 




0.5 
0.15 


mA/ 
MHz 


Isby 


Standby Current Outputs Unloaded 
BE, IRQB, NMIB, PHI2, SOB=VDD 




1 




1 




1 




1 




1 


uA 


Cin 
Cts 


♦Capacitance (Vin=OV, TA=25°C, f-lMHz) 
BE, IRQB, NMIB, PHI2, RESB, RDY, SOB 
A0-A15, D0-D7, RWB 

*Not inspected during production test; verified on a sample basis. 




5 




5 




5 




5 




5 


pF 



(1) For high speed tests, Vih and Vil are set for VDD-.2v and VSS+.2V. The input "1" and "0" thresholds are tested at 1 MHz. 




Vdd (VOLTS) 

Figure 6-2 FMaxvsVdd 

Figure 6-1 Idd vs Vdd 
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6.2 AC Characteristics TA = -40 ° C to +85 ° C (PLCC, QFP) TA= ° C to 70°C (DIP) 

Table 6-3 AC Characteristics 



Symbol Parameter 


5.0 +/-5% 


3.3 +/-10% 


3.0+/-5% 


2.5 +/-5% 


1.8+/-5% 


Units 


14MHz 


8MHz 


8MHz 


4MHz 


2MHz 


Min 


Max 


Min 


Max 


Min 


Max 


Min 


Max 


Min 


Max 


VDD 


Supply Voltage 


4.75 


5.25 


3.0 


3.6 


2.85 


3.15 


2.375 


2.675 


1.71 


1.89 


V 


tACC 


Access Time 


30 




70 




70 




145 




290 




nS 


tAH 


Address Hold Time 


10 




10 




10 




10 




10 




nS 


tADS 


Address Setup Time 




30 


- 


40 


- 


40 


- 


75 


- 


150 


nS 


tBVD 


BE to Valid Data (1) 




25 




30 




30 




30 




30 


nS 


CEXT 


Capacitive Load (2) 




35 




35 




35 




35 




35 


pF 


tPWH 


Clock Pulse Width High 


35 




62 




62 




125 




250 




nS 


tPWL 


Clock Pulse Width Low 


35 




63 




63 




125 




250 




nS 


tCYC 


Cycle Time (3) 


70 




125 




125 




250 




500 




nS 


tF,tR 


Fall Time, Rise Time 




5 




5 




5 




5 




5 


nS 


tPCH 


Processor Control Hold Time 


10 




10 




10 




10 




10 




nS 


tPCS 


Processor Control Setup Time 


10 




15 




15 




30 




60 




nS 


tDHR 


Read Data Hold Time 


10 




10 




10 




10 




10 




nS 


tDSR 


Read Data Setup Time 


10 




15 




15 




30 




60 




nS 


tMDS 


Write Data Delay Time 




25 




40 




40 




70 




140 


nS 


tDHW 


Write Data Hold Time 


10 




10 




10 




10 




10 




nS 




1 . BE to High Impedance State is not testable but should be the same amount of time as BE to Valid Data 

2. ATE or loading on all outputs 

3 . Since this is a static design, the maximum cycle time could be infinite. 
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tF 



PHI2 



A0-A15. MLB, 
R/W, SYNC, VPB 



Read Data 



Write Data 



^ADS 



tDHR 



tDHW 



SOB 



IRQB, NMIB 
RDY, RESB 



SOB 



DATA 



tPWL 



<— tAH 



^\ /V 



><: 



"tPWH 



.tACC 



"tPCS 



X 



-tMDS 



•tPCH 
tPCH 



X 



-tAH 

see note 1 



tDSR 



XX 



-tDHR 



XX 

XX 



■tDHW 



tPCS 



X 



X 



-tBVD 



Figure 6-3 General Timing Diagram 



Timing Notes: 

1 . Timing measurement points are 50% VDD. 

2. PHIIO and PHI20 clock delay from PHI2 is no longer specified or tested and WDC recommends using an oscillator for system time base and PHI2 
processor input clock. 
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Table 6-4 Operation, Operation Codes and Status Register 



Mnemomic 


p>rn ti i\n 
WlJCl aliUil 

# Immediate Data 

-NOT 

A AND 

VOR 

-V- Exclusive OR 




'>? 








< 










a 

N 


(zp,x) 


x'dz 


ci 

N 


(dz) 


>. 


Processor Status Register (?) 
*User Defined 

7 6 5 4 3 2 1 


1 


2 


3 


4 


5 


6 


7 


8 


9 


10 


11 


12 


13 


14 


15 


16 


N V 1 1 D I Z C 


ADC 

AND 
ASL 


A+M+C^A 
AAM^A 

C<- 76543210 .^0 


6D 
2D 
OE 




7D 
3D 
IE 


79 
39 




OA 


69 
29 








65 
25 
06 


61 
21 


75 
35 
16 




72 
32 


71 
31 


N V . . . . Z C 

N Z . 

N Z C 


BBRO 
BBRl 
BBR2 


Branch on bit reset 

Branch on bit 1 reset 
Branch on bit 2 reset 


















OF 
IF 
2F 


















BBR3 
BBR4 
BBR5 


Branch on bit 3 reset 

Branch on bit 4 reset 
Branch on bit 5 reset 


















3F 
4F 
5F 


















BBR6 

BBR7 
BBSO 


Branch on bit 6 reset 

Branch on bit 7 reset 
Branch on bit set 


















6F 
7F 
8F 


















BBSl 

BBS2 
BBS3 


Branch on bit 1 set 

Branch on bit 2 set 
Branch on bit 3 set 


















9F 
AF 
BF 


















BBS4 

BBSS 
BBS6 


Branch on bit 4 set 

Branch on bit 5 set 
Branch on bit 6 set 


















CF 
DF 
EF 


















BBS7 

BCC 
BCS 


Branch on bit 7 set 

Branch C = 
Branch ifC = 1 


















FF 
90 
BO 


















BEQ 

BIT 

BMI 


BranchifZ = 1 

A AM 

Branch ifN = 


2C 




3C 








89 




FO 
30 




24 




34 








M- Ms . . . Z 


BNE 
BPL 
BRA 


BranchifZ = 

Branch ifN = 
Branch Always 


















DO 
10 

80 
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Mnemomic 


Operation 

# Immediate Data 

-NOT 

A AND 


























x'dz 








Processor Status Register (P) 
*User Defined 


V OR 












<; 










N 






/ 


J ^ DA i 


u 


-v^ Exclusive OR 


1 


2 


3 


4 


5 


6 


7 


8 


9 


10 


11 


12 


13 


14 


15 


16 


N 


VI 1 D I Z 


c 


BRK 

BVC 


Break 

Brancli ifV = 


















50 


00 
















10 1. 




BVS 


Brancli if V = 1 


















70 






















CLC 


C — > 
















18 

























CLD 


-» D 
















D8 

























CLI 


-> 1 
















58 
























CLV 


-> V 
















B8 
























CMP 


A-M 


CD 




DD 


D9 






C9 








C5 


CI 


D5 




D2 


Dl 


N 


Z 


c 


CPX 


X-M 


EC 












EO 








E4 












N 


Z 


c 


CPY 


Y-M 


CC 












CO 








C4 












N 


Z 


C 


DEC 


Decrement 


CE 




DE 






3A 










C6 




D6 








N 


Z 




DEX 


X-1 -> A 
















CA 


















N 


z 




DEY 


Y-1 — > Y 
















88 


















N 


Z 




EOR 


Ai/M^A 


4D 




5D 


59 






49 








45 


41 


55 




52 


51 


N 


z 




INC 


Increments 


EE 




FE 






lA 










E6 




F6 








N 


z 




INX 


X+1 
















E8 


















N 


z 




INY 


Y+1 ->Y 
















C8 


















N 


z 




JMP 


Jump to new location 


4C 


7C 






6C 






























JSR 


Jump to Subroutine 


20 
































N 


z 




LDA 


M->A 


AD 




BD 


B9 






A9 








A5 


Al 


B5 




B2 


Bl 


N 


z 




LDX 


M->X 


AE 






BE 






A2 








A6 






B6 






N 


z 




LDY 


M-> Y 


AC 




BC 








AO 








A4 




B4 








N 


z 




LSR 


0->765432 1 0-»C 


4E 




5E 






4A 










46 




56 











z 


c 


NOP 


No Operation 
















EA 
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Mnemomic 


Operation 

# Immediate Data 

-NOT 

A AND 

vOR 

V Exclusive OR 












< 










N 


(zp,x) 


x'dz 


d 

N 


(dz) 




Processor Status Register (P) 
*User Defined 

7 6 5 4 3 2 1 


1 


2 


3 


4 


5 


6 


7 


8 


9 


10 


11 


12 


13 


14 


15 


16 


N V 1 1 D I Z C 


ORA 
PHA 
PHP 


AVM->A 

A -> Ms, S-1 -> S 

r — > Ms, a-1 — > a 


OD 




ID 


19 






09 






48 


05 


01 


15 




12 


11 


N Z . 


PHX 
PHY 
PLA 


X->Ms, S-1 ->S 
Y^Ms, S-1 ->S 

a + 1 — > 0, Ms — > A 




















DA 
5A 
68 














N . . . . . Z . 


PLP 
PLX 
PLY 


S + 1 ^ S, Ms ^ P 
S + 1 ^ S, Ms ^ X 

b + 1 — > o, MS — > Y 




















28 
FA 

In 














N V . 1 D I Z C 
N Z . 


RMBO 
RMBl 
RMB2 


Reset Memory Bit 
Reset Memory Bit 1 
Reset ^^emory Bit 2 






















07 
17 

27 














RMB3 
RMB4 
RMB5 


Reset Memory Bit 3 
Reset Memory Bit 4 
Reset Memory Bit 5 






















37 
47 
57 














RMB6 
RMB7 
ROL 


Reset Memory Bit 6 
Reset Memory Bit 7 
C<-7 6543210<-C 


2E 




3E 






2A 










67 
77 
26 




36 








N Z C 


ROR 

RTI 
RTS 


C^7 6543210->C 

Return from Interrupt 
Return from Subroutine 


6E 




7E 






6A 








40 
60 


66 




76 








N Z C 

N V . 1. D I Z C 


SBC 

SEC 
SED 


A - M - (~C) -> A 
1 

1 ->D 


ED 




FD 


F9 






E9 


38 
F8 






E5 


El 


F5 




F2 


Fl 


N V . . . . Z C 

1 

1 . . . 
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Mnemomic 


Operation 

# Immediate Data 

-NOT 

A AND 

vOR 

^ Exclusive OR 












< 




._ 






N 


(zp,x) 


x'dz 


d 

N 


(dz) 




Processor Status Register (?) 
*User Defined 

7 6 5 4 3 2 1 


1 


2 


3 


4 


5 


6 


7 


8 


9 


10 


11 


12 


13 


14 


15 


16 


N V 1 1 D I Z C 


SEI 

SMBO 

SMBl 


1^1 

Set Memory Bit 

Set Memory Bit 1 
















78 






87 

V / 












1 


SMB2 
SMB3 
SMB4 


Set Memory Bit 2 
Set Memory Bit 3 
Set Memory Bit 4 






















A7 
B7 
C7 














SMB5 
SMB6 
SMB7 


Set Memory Bit 5 
Set Memory Bit 6 
oet iviemory rjii / 






















D7 

E7 
F7 














STA 
STP 
STX 


A^M 

STOP (1->PHI2) 
X — > M 


8D 

8E 




9D 


99 








DB 






85 

86 


81 


95 


96 


92 


91 




STY 
STZ 
TAX 


Y^M 
00 — > M 
A->Y 


8C 
9C 




9E 










AA 






84 
64 




94 
74 








N Z . 


TAY 
TRB 
TSB 


A->X 
~AAM M 
AVM->M 


IC 
OC 














AB 






14 
04 












N Z . 

Z 

z 


TSX 

TXA 
TXS 


S->X 
X^ A 
X->S 
















BA 
8A 
9A 


















N Z . 

N Z . 


TYA 
WAI 


Y->A 
O^RDY 
















98 
CB 


















N Z . 
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Table 6-5 Instruction Timing Chart 



1 , , T-r-: 1 

AddrGss JVIoqg 


oe — 


Cycle 


VPB 


MLB 


SYNC 


1 — TTa 5 1 

AQdress IjUS 




Data Bus 


RWB 


la. Absolute a 




1 




1 


1 


PC 


OpCode 




ADC, AND, BIT, CMP, CPX, CPY, EOR, 


(6) 


2 




1 





PC+1 


AAL 




LDA, LUX, LUY, UKA, &dC, olA, blX, 




3 




1 





PC+2 


AAH 




STY, STZ 




4 




1 





AA 


Data 


1/0 


io OpLodes, j bytes, 4ocj cycles 


















lb. Absolute (R-M-W) a 




1 




1 


1 


PC 


OpCode 




ASL, DEC, INC, LSR, ROL, ROR, TRB, 




2 


1 


1 





PC+1 


AAL 


1 


TSB 




3 




1 





PC+2 


AAH 




8 OpCodes, 3 bytes, 6 cycles 




4 










AA 


Data 








5 










AA 


IO 








6 










AA 


Data 




Ic. Absolute (JUMP) a 




1 




1 


1 


PC 


OpCode 




JMP (4C) 




2 


1 


1 





PC+1 


New PCL 


1 


1 OpCode, 3 bytes, 3 cycles 




3 


1 


1 





PC+2 


New PCH 


1 






1 




1 


1 


New PC 


New OpCode 




Id. Absolute (JUMP to subroutine) a 




1 




1 


1 


PC 


OpCode 




JSR (20) 




2 




1 





PC+I 


New PCL 




1 OpCode, 3 bytes, 3 cycles 




3 




1 





S 


10 


1 


(different order from N6502) 




4 


1 


1 





s 


PCH 








5 









S+1 


PCL 








6 









PC+2 


New PCH 








1 






1 


New PC 


New OpCode 




2. Absolute Indexed Indirect (a, x) 




1 






1 


PC 


OpCode 


1 


JMP (7C) 




2 









PC+1 


AAL 


1 


1 OpCode, 3 bytes, 6 cycles 


(1) 


3 









PC+2 


AAH 


1 






4 









PC+2 


10 


1 






5 









AA+X 


New PCL 








6 









AA+X+I 


New PCH 








1 






1 


New PC 


OpCode 




3a. Absolute , X a, x 




1 


1 


1 


1 


PC 


OpCode 


1 


ADC, AND, BIT, CMP, EOR, LDA, LDY, 




2 









PC+1 


AAL 




ORA, SBC, STA, STZ 


(1) 


3 









PC+2 


AAH 




1 1 OpCodes, 3 bytes, 4,5 and 6 cycles 


(6) 


4 









AA+X 


Data 


1/0 


3b. Absolute, X(R-M-W) a, x 


(1) 


1 


1 


1 


1 


PC 


OpCode 


1 


ASL, DEC, INC, LSR, ROL, ROR 




2 


1 


1 





PC+1 


AAL 


1 


6 OpCodes, 3 bytes, 7 cycles 




3 


1 


1 





PC+2 


AAH 


1 






4 




I 





AAH,AAL+X 


IO 


1 






5 










AA+X 


Data 








6 










AA+X+1 


IO 








7 










AA+X 


Data 




4. Absolute, Y a, y 




1 






1 


PC 


OpCode 




ADC, AND, CMP, EOR, LDA, LDX, ORA, 


(1) 


2 









PC+1 


AAL 




SBC, STA 


(6) 


3 









PC+2 


AAH 




9 OpCodes, 3 bytes, 4,5 and 6 cycles 




4 









AA+Y 


Data 


1/0 


5. Absolute Indirect (a) 




1 






1 


PC 


OpCode 




JMr (oC) 




2 









PC+1 


AAL 




1 OpCode, 3 bytes, 6 cycles 




3 









PC+2 


AAH 








4 









PC+2 


10 








5 









0,AA 


New PCL 








g 


[ 


[ 





AA+1 


New PCH 


j 






1 






1 


New PC 


OpCode 




6. Accumulator A 




1 






1 


PC 


OpCode 




ASL, DEC, INC, LSR, ROL, ROR 




2 









PC+1 


IO 




6 OpCodes, 1 byte, 2 cycles 


















7. Immediate # 




1 






1 


PC 


OpCode 




ADC, AND, BIT, CLR, CMP, CPY, CPX, 


(6) 


2 









PC+1 


ID 




EOR, LDA, LDX, LDY, ORA, SBC 


















1 3 OpCodes, 2 bytes, 2 and 5 cycles 


















8a. Implied i 




1 






1 


PC 


OpCode 




CLC, CLD, CLI, CLV, DEX, DEY, INX, 




2 









PC+I 


10 




INY, NOP, SEC, SED, SEI, TAX. TAY, 


















TXA. TSX. TXS, TYA 


















18 OpCodes, 1 byte, 2 cycles 
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1 , , rj— 5 1 

Aadress Mode 


— 

JNote 


Cycle 


VPB 


MLB 


O 1 I Nl^ 


1 TaA D 1 




Data Bus 


RWB 


8b. Stop the Clock i 




1 






1 


PC 


OpCode 




STP 




2 









PC+1 


lO 




1 OpCode, 1 byte, 3 cycles 




3 









PC+1 


lO 




RESB=1 




Ic 









PC+1 


RES(BRK) 




KbSB— U 




lb 









PC+1 


rjT^c"/Tir>T^\ 
RiiS(Bk1s.) 




RESB=0 




la 









PC+1 


RES(BRK) 




RESB=1 




1 






1 


PC+1 


BEGIN 




8c. Wait for Intermpt i 




1 






1 


PC 


OpCode 




WAI 


(4) 


2 









PC+1 


lO 




1 Opcode, 1 byte, 3 cycles 




3 









PC+1 


lO 




IRQB NMIB 




1 






1 


PC+1 


IRQ(BRK) 




9a. Relative r 




1 


1 


1 


1 


PC 


OpCode 


1 


BCC, BCS, BEQ, BMI, BNE, BPL, 


(2) 


2 


1 


1 





PC+1 


Offset 


1 


BRA, BVC, BVS 


(3) 


1 






1 


New PC 


OpCode 




9 OpCodes, 2 bytes, 2,3 and 4 cycles 


















9b. Relative Bit Branch r 


(2) 


1 






1 


PC 


OpCode 




BBRx, BBSx 


(3) 


2 









PC+1 


zp 




16 OpCodes, 3 bytes, 5,6 and 7 cycles 




3 


1 







0,zp 


Data 


1 






4 









PC+2 


Offset 


1 






5 









PC+Offset 


New OpCode 




10a. Stacks 




1 


1 


1 


1 


PC 


not used 


1 


ABORTB, IRQB, NMIB, RESB 




2 


1 


1 





PC 


not used 


1 


4 hardware interrupts, bytes, 7 cycles 




3 


1 







01,S 


Return PCH 







(5) 


4 









01,S-1 


Retiun PCL 









5 









01,S-2 


Return P 









6 




I 





VA 


New PCL 


1 






7 









VA-I 


New PCH 


1 






1 






1 


New PC 


i\c\v OpCode 


1 


10b. Stack (Software Interrupts) s 




1 


1 


1 


1 


PC 


OpCode 


1 


BRK 




2 


1 







PC+1 


not used 


1 


1 OpCode, 2 bytes, 7 cycles 




3 


1 







S 


Return PCH 









4 


1 







S-1 


Return PCL+2 









5 


1 







S-2 


Return P 









6 




1 





VA 


New PCL 


1 






7 


1 


1 


1 


VA+1 


New PCH 


1 






1 








New PC 


New OpCode 


1 


10c. Stack (Return from interrupt) s 




1 






1 


PC 


OpCode 




RTI 




2 


1 







PC+1 


Not Used 


1 


1 OpCode, 1 byte, 6 cycles 




3 









S+1 


Return P 








4 









S+2 


Return PCL 








5 









S+3 


Return PCH 








6 









PC+1 


lO 








1 






1 


Return PC 


New OpCode 




lOd. Stack (Return from subroutine) s 




1 






1 


PC 


OpCode 




RTS 




2 









PC+1 


not used 




1 OpCode, 1 byte, 6 cycles 




3 









PC+1 


not used 








4 









S+1 


Return PCL 








5 









s+2 


Return PCH 








6 









PC+1 


lO 








1 







1 


Return PC 


New OpCode 




1 Ue. oldLK S 




^ 


— 






pr* 

r 


VjpL>OUC 


— 


PHA, PHP, PHX. PHY 




2 









PC+1 


not used 




4 OpCodes, 1 byte, 3 cycles 




3 









s 


Register Value 








1 






1 


PC+1 


New OpCode 




lot". Stack s 




1 






1 


PC 


OpCode 




PLA, PLP, PLX, PLY 




2 









PC+1 


not used 




4 OpCodes, 1 byte, 4 cycles 




3 









PC+1 


not used 








4 









s+1 


Register Value 








1 






1 


PC+1 


New OpCode 




Ua. Zero Page zp 




1 






1 


PC 


OpCode 




ADC, AND, BIT, CMP, CPX, CPY, 




2 









PC+1 


zp 




EOR, LDA, LDX, LDY, ORA, SBC, 




3 









0,zp 


Data 


1/0 


STA, STX, STY, STZ 




1 






1 


PC+2 


New OpCode 




16 OpCodes, 2 bytes, 3 and 4 cycles 
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1 , , T-r-: 1 


— r 

e 1 


Cycle 1 


VPB 


MLB 


O 1 I Nl^ 


1 TaA D 1 

Adtiress IjUS 




L)ata Bus 


RWB 


lib. Zero Page zp 




1 




1 


1 


PC 


OpCode 


1 


ASL, DEC, INC, ROL, ROR, TRB, TSB 




2 




1 





PC+1 


zp 


1 


7 Opcodes 




3 










PC+1 


Data 








4 










zp 


not used 








5 










zp 


Data 








1 

i 


— ! 




1 
1 




New OpCode 




11c. Zero Page zp 




1 


[ 


— 

[ 


1 


PC 


upL.oae 


— 


RMRx SMRx 




2 









PC+1 


zp 








3 


. 


. 





zp 


Data 








4 




y 





ZD 


not used 








5 









zp 


Data 




1 Id. Zero Page zp 




1 




y 


1 


PC 


OpCode 




BBRx, BBSx 




2 




y 





PC+1 


zp 




16 OpCodes, 3 bytes, 5 cycles 




3 


1 


1 





zp 


Data 


1 






4 


1 


1 





PC+2 


Offset 


1 






5 


1 


1 





PC+3 


not used 


1 






1 


1 


1 


1 


PC+2+OOffset 


New OpCode 


1 


12. Zero Page Indexed Indirect (zp,x) 




1 


1 


1 


1 


PC 


OpCode 


1 


ADC, AND, CMP, EOR, LDA, ORA, 




2 


1 


1 





PC+1 


zp 


1 


SBC, STA 




3 


1 


1 





PC+1 


not used 


1 


8 OpCodes, I byte, 5 cycles 




4 


1 


1 





0,zp+X 


Indirect address 


1 






5 


1 


1 





Indirect address 


Data 


1 






1 


1 


1 


1 


PC+1 


New OpCode 


1 


13a. Zero Page Indexed with X zp,x 




1 


1 


1 


1 


PC 


OpCode 


1 


ADC, AND, BIT, CMP, EOR, LDA, 




2 


1 


1 





PC+1 


zp 


1 


ORA, LDY, SBC, STA, STY, STZ 




3 


1 


1 





PC+1 


not used 


1 


12 OpCodes, 1 byte, 4 cycles 




4 


1 


1 





0,zp+X 


Data 


1/0 






1 


1 


1 


1 


PC+1 


New OpCode 


1 


13b. Zerp Page Indexed with X zp,x 




1 


1 


1 


1 


PC 


OpCode 


1 


ASL, DEC, INC, LSR, ROL, ROR 




2 


1 


1 





PC+1 


zp 


1 


6 OpCodes, 1 byte, 6 cycles 




3 


1 


1 





PC+1 


not used 


1 






4 


1 








0,zp+X 


Data 


1 






5 


1 








0,zp+X 


not used 


1 






6 










0,zp+X 


Data 








1 


1 


1 


1 


PC+1 


New OpCode 


1 


14. Zero Page Indexed with Y zp,y 




1 


1 


1 


1 


PC 


OpCode 


1 


ADC, AND, CMP, EOR, LDA, LDX, 




2 


1 


1 





PC+1 


zp 


1 


ORA, SBC, STA, STX 




3 




1 





PC+1 


not used 




10 OpCodes, 1 byte, 4 cycles 




4 









0,zp+Y 


Data 


1/0 






1 






1 


PC+1 


New OpCode 




15. Zero Page Indirect (zp) 




1 






1 


PC 


OpCode 




ADC, AND, CMP, EOR, LDA, ORA, 




2 









PC+1 


zp 




SBC, STA 




3 









0,zp 


Indirect address 




8 OpCodes, 1 byte, 4 cycles 




4 









Indirect address 


Data 


1/0 






1 






1 


PC+1 


New OpCode 




16.. Zero Page Indirect Indexed with y 




1 






1 


PC 


OpCode 




(zp),y 




2 









PC+1 


zp 




ADC, AND, CMP, EOR, LDA, ORA, 




3 









0,zp 


Indirect address HIGH 




SBC, STA 


(6) 


4 









0,zp+l 


Indirect address LOW 




8 OpCodes, 1 byte, 4, 5 and 6 cycles 


(1) 


5 









Indirect address+y 


Data 


1/0 






5a 









PC+2 


New OpCode 
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Notes: 



1. Add 1 cycle for indexing across page boundaries, or write. This cycle contains invalid addresses. 

2. Add 1 cycle if branch is taken. 

3. Add 1 cycle if branch is taken across page boundaries. 

4. Wait at cycle 2 for 2 cycles after NMIB or IRQB active input. 

5. RWB remains high during Reset. 

6. Add 1 cycle for decimal mode 



AAH 


Absolute Address 


PC 


Program Counter 


AAH 


Absolute Address High 


PCH 


Program Counter High 


AAL 


Absolute Address Low 


PCL 


Program Counter Low 


AAVH 


Absolute Address Vector High 


R-M-W 


Read-Modify- Write 


AAVL 


Absolute Address Vector Low 


REG 


Register 


C 


Accumulator 


S 


Stack Address 


BEST 


Destination 


SRC 


Source 


ID 


Immediate Data 


SO 


Stack Offset 


10 


Intemal Operation 


V 


Vector Address 


P 


Status Register 


x,y 


Index Register 



zp 



Zero Page Address 
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7 CAVEATS 



Table 7-1 Microprocessor Operational Enhancements 



Function 


NMOS 6502 


W65C02S 


Indexed addressing across page 
boundary 


Extra read of invalid address. 


Extra read of last instruction byte. 


Execution of invalid OpCodes. 


Some terminate only by reset. 
Results are undefined. 


All are NOP's (reserved for future use). 
OpCode Bytes Cycles 
02,22,42,62,82 2 2 
C2, E2 

X3,OB-BB,EB,FB 1 1 
44 2 3 
54,D4,F4 2 4 
5C 3 8 
DC,FC 3 4 


Jump indirect, operand = XXFF. 


Page address does not increment. 


Page address increments, one additional 
cycle. 


Read/Modify /Write instruction at 
effective address. 


One read and two write cycles. 


Two read and one write cycle. 


Decimal flag. 


Indeterminate after reset. 


Initialized to binary mode (D=0) after reset 
and interrupts. 


Flags after decimal operation. 


Invalid N, V and Z flags. 


Valid flags. One additional cycle. 


Interrupt after fetch of BRK 
instruction 


Interrupt vector is loaded; BRK 
vector is ignored. 


BRK is executed, and then interrupt is 
executed. 


Ready. 


Input. 


Bi-directional, WAI instruction pulls low. 


Read/ModifyAVrite instructions 
absolute indexed in same page. 


Seven cycles. 


Six cycles. 


Oscillator. 


Requires external active components. 


Crystal or RC network will oscillate when 
connected bclwccn P11I2 and PllllO. 


Assertion of Ready (RDY) during 
write operations. 


Ignored. 


Stops processor during PHI2, and WAI 
instruction pulls RDY low. 


Clock inputs. 


PHI2 is the only required clock. 


PHI2 is the only required clock. 


Unused input-only pins. 


Must be tied to VDD. 


Must be tied to VDD. 



The BRK instruction for both the NMOS 6502 and 65C02 is a 2 byte instruction. The NMOS and CMOS devices 
simply skips the second byte (i.e. doesn't care about the second byte) by incrementing the program counter twice. 
It is important to reaUze that if a return from interrupt is used it will return to the location after the second or 
signature byte. 
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8 HARD CORE MODEL 

8.1 Features of the W65C02S Hard Core Model 

• The W65C02S core uses the same instruction set as the W65C02S. 

• The only functional difference between the W65C02S and W65C02S core is the RDY pin. The W65C02S RDY pin is 
bi-directional utilizing an active pull-up. The W65C02S core RDY function is split into 2 pins, RDY, WAITN and 
WAITP. The WAITN output goes low and WAIT? goes high when a WAI instruction is executed. 

• The ESD and latch-up buffers have been removed. 

• The output from the core is the buffer N-channel and the P-channel transistor drivers. 

• The foUowmg mputs, if not used, must be pulled to the high state: RDY, IRQB, NMLB, BE and SOB. 

• The timing of the W65C02S core is the same as the W65C02S. 

9 SOFT CORE RTL MODEL 

9.1 W65C02 Synthesizable RTL-Code in VerUog HDL 

The RTL-Code (Register Transfer Level) in Verilog is a synthesizable model. The behavior of this model is equivalent to 

the original W65C02S hardcore. The W65C02 RTL-Code is available as the core model and the W65C02S standard chip 
model. The standard chip model includes the soft-core and the buffer ring in RTL-Code. 
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10 ORDERING INFORMATION 



W65C02S6PL-14 


Description 

W65C = standard product 


W65C 


Product Identification Number 


02S 


Foundry Process 

Blank = 1.2u 
8=.8u, 6=.6u 


6 


Package 

P = Plastic Dual-In-Line, 40 pins 

PL = Plastic Leaded Chip Carrier, 44 pins 

Q = Quad Flat Pack, 44 pins 


PL 


Temperature/Processing 

Blank = -40°C to + 85 °C (PLCC and QFP) 0°C to 70°C (DIP) 




Speed Designator 

-14= 14MHz 


-14 



To receive general sales or technical support on standard product or information about our module library licenses, 
contact us at: 

The Western Design Center, Inc. 
2 1 66 East Brown Road 
Mesa, Arizona 85213 USA 
Phone: 480-962-4545 Fax: 480-835-6442 
information@westemdesigncenter.com 
www.westemdesigncenter.com 



WARNING: MOS CIRCUITS ARE SUBJECT TO DAMAGE FROM STATIC DISCHARGE 

Internal static discharge circuits are provided to minimize part damage due to environmental static electrical charge 
build-ups. Industry established recommendations for handling MOS circuits include: 

1. Ship and store product in conductive shipping tubes or conductive foam plastic. Never ship or store product in 
non-conductive plastic containers or non-conductive plastic foam material. 

2. Handle MOS parts only at conductive work stations. 

3 . Ground all assembly and repair tools. 




The Western Design Center, Inc. 



W65C02S Datasheet 



38 



